Receiver for a spread spectrum system

ABSTRACT

The present invention discloses a method for operation of a receiver of a spread spectrum system in which a signal received at the receiver has a received time and frequency and is transmitted from a transmitter in accordance with a predetermined modulation scheme and having a transmitted time and frequency, there being a time offset and a frequency offset between the received signal and the transmitted signal, and in which the receiver includes a predefined correlation surface in accordance with the predetermined modulation scheme, the method comprising:  
     generating in the receiver an expected signal, the expected signal being a function of time and frequency comprising a frequency parameter shifted from the transmitter frequency and a time parameter shifted from the transmitter time,  
     correlating the received time and frequency of the received signal with said time and frequency shifted parameters of the expected signal to provide respective correlation measures therebetween,  
     deriving, using said correlation surface, a computational expression indicative of the value of the correlation at a point displaced in time by the time offset plus the time shift and displaced in frequency by the frequency offset plus the frequency shift, and  
     comparing the correlation measure with the computational expression to determine the time offset and the frequency offset.

[0001] The present invention is applicable in spread spectrum telecommunication systems and more specifically relates to receivers for use in such systems.

[0002] In telecommunications, two common examples of spread spectrum systems are CDMA and WCDMA. Other examples include the Global Positioning System (GPS). Global positioning system (GPS) is one example of a space based satellite navigation system that has the ability to pinpoint any location on earth with a high degree of accuracy, providing information on position, velocity and time (PVT) of a receiver. Other examples of spaced based satellite navigation system are TIMATION, transit, and GLONASS.

[0003] GPS is typically divided into three segments:

[0004] a space segment which essentially comprises the satellites and the signals they emit,

[0005] a control segment which monitors and maintains the satellite constellation,

[0006] a user segment which comprises GPS receivers, equipment, data collection and data processing techniques.

[0007] The GPS constellation typically consists of 24 satellites orbiting the earth every 24 hours. A minimum of four GPS satellites must be in clear view of a GPS receiver in order for the receiver to determine accurately its location. In overview, each satellite broadcasts signals that the GPS receiver receives and decodes and from these calculates the time taken for the signals to reach the receiver, this is called the time in transit. The receiver then multiplies the time in transit by the speed of electromagnetic radiation to determine the range from the satellite to the receiver. From there, in order to work out the receiver's 3 dimensional distance, velocity and time, the receiver applies the triangulation calculation. Triangulation involves calculating the intersection of points between four reference points given by the satellites and the intersection fixes or locates the position in 3-dimensional space.

[0008] It should be noted, however, that range measurement inherently contain errors common to measurements created by the unsynchronised operation of the satellite and the user clocks. This is why GPS uses four satellites to effect ranging. The measurements from three GPS satellites allow the GPS receiver to calculate the three unknown parameters representing its three dimensional position, while the fourth GPS satellite allows the GPS receiver to calculate the user clock error and therefore determine a more precise time measurement.

[0009] The signals broadcast by a satellite comprise radio frequency (RF) ranging codes and navigation data messages which are transmitted using spread spectrum techniques. The ranging codes enable the GPS receiver to measure the transit times of the signals and thereby determine the range between the satellite and the receiver. The navigation data messages are based on predetermined information regarding the orbital path of the satellite and thus provide an indication of the position of the satellite at the time the signals were transmitted.

[0010] The encoded signal generated by a satellite is in the form of a pseudo random noise (PRN) code which represents a sequence of random binary chips, each satellite transmitting a unique PRN sequence that repeats itself at definite intervals. In GPS, there is Precision Code (P-Code) having a chipping rate 10.23 MHz and which is reserved for military use, and a Course Acquisition code (C/A Code) having a chipping rate 1.023 MHz and which is allocated for commercial and personal use. A chip is 1 or −1. The codes are transmitted on two L-band frequencies: Link 1 (L1) at 1575.42 MHz and Link 2 (L2) at 1227.6 MHz. The code allocations on L1 are Course Acquisition code (C/A Code) and Precision Code (P-Code), and on L2 is only P-Code.

[0011] The C/A Code consists of a 1023 bit pseudo random (PRN) code, and a different PRN code is assigned to each GPS satellite. In addition, a 50 Hz navigation data message is superimposed on the C/A Code, and contains the data noted above. Thus the receiver can utilise the signal from a satellite by the particular C/A Code being submitted, to make pseudo-range measurements.

[0012] Turning now to the receivers, there is a wide range of GPS receivers available today, and typically the internal architecture of a GPS receiver comprises a front end that initially processes the incoming satellite signals, followed by signal processing stages that apply the algorithms to determine the receivers location, speed and time.

[0013] The front end in basic terms is similar to that of a superheterodyne receiver. The signal is detected by a GPS antenna and fed to a low noise amplifier. Following amplification, the signal is down converted to a lower workable frequency. This is achieved by mixing or heterodyning the GPS signal with another constant frequency signal. This mixing signal is produced by a local oscillator. When two signals are mixed, the original, the sum of the two and the difference between the two frequencies is output. The filter in the following stages selects only the difference frequency and rejects the others. This difference frequency produced by the down conversion step is known as the intermediate frequency IF. The signal is next converted from analogue to digital in an AD converter. The output level of the AD converter is monitored by a voltage comparator to check levels exceeding or dropping below threshold levels, and an automatic gain control continually adjusts the gain of the IF amplifier to maintain a constant output level. The digital signal from the AD converter is used as an input to several stages of signal processing dealing with the ranging process.

[0014] As indicated earlier, the ranging process aims to calculate the distance from the satellite to the receiver using the incoming PRN codes to time how long it has taken the signals transmitted by the satellite to arrive at the receiver. To achieve this, each receiver has the capability to generate an exact pattern of the code that each satellite transmits using a PRN signal generator. The incoming signal received from a particular satellite is likely to be out of phase with the internal one since the time it takes to travel from the satellite to the receiver, measured in units of time periods to transmit a chip may not be always known. The internally generated expected PRN signal from a particular satellite needs to be suitably delayed or phase shifted so that it matches with the received signal when compared. The strength of match can be measured from correlation between the two signal fragments. It is usual to correlate a fragment of the received sequence with a corresponding fragment of the expected signal from the satellite. As the digitised expected signal is periodic, the internally generated sequence can be delayed by rotating the sequence. The amount of shifting or offset that was required to match the two signals provides the receiver with a measurement of the time lag between the signal leaving the satellite and arriving at the receiver. This measurement is then used to derive the range.

[0015] In principle, if the time it takes for the signal to travel from the satellite to the receiver via a particular path were known, then it would be possible to predict a signal proportional to the signal arriving at the receiver via that path and the output from the correlator would be a large quantity related to the energy in that path. However, this time interval is not known to begin with. It is usual to acquire the exact time of travel for each significant path by using some form of search algorithm. As the signal is cyclic (at least for 20 ms) by shifting the fragment of expected signal by m shift positions, a delay of m multiplied by the sampling period in microseconds can be simulated. Various delays are tried and the output of the correlator is monitored. The delay that is identified as being the one that is appropriate is the one that yields the highest correlation output. If sub chip sampling is employed, (say 4 samples per chip which is currently common) then a high value is obtained for about 4 of the m rotations. The rotation that yields the highest correlation from these four contiguous rotations is used to calculate the time the signal has taken to travel from the satellite to the observer. Once the time has been estimated, the changes in this time are monitored using various tracking algorithms.

[0016] Referring more generally to spread spectrum systems, all the information transmitted is not retrievable from a single received pulse. For example in WCDMA each data element is modulated using a code comprising a string of positive and negative bits specific to an individual system user to create a set of data pulses. The entire set is transmitted. This allows the value of the data element to be retrieved even if only a subset of the pulses transmitted is accurately received. The value of the bit is, however, calculated using all the received pulses both accurate and inaccurate rather than from an individual pulse as in analogue systems.

[0017] Accordingly, spread spectrum systems like WCDMA employ broadly analogous synchronisation techniques to those described above in relation to the GPS ranging process. For example, in a WCDMA receiver, user data is retrieved from a desired spread signal by a de-spreading code known to the receiver, provided there is accurate synchronisation between the spread user signal and the (de)spreading code.

[0018] Against this background, the present invention in one aspect provides a method for operation of a receiver of a spread spectrum system in which a signal received at the receiver has a received time and frequency and is transmitted from a transmitter in accordance with a predetermined modulation scheme and having a transmitted time and frequency, there being a time offset and a frequency offset between the received signal and the transmitted signal, and in which the receiver includes a predefined correlation surface in accordance with the predetermined modulation scheme, the method comprising:

[0019] generating in the receiver an expected signal, the expected signal being a function of time and frequency comprising a frequency parameter shifted from the transmitter frequency and a time parameter shifted from the transmitter time,

[0020] correlating the received signal based on the transmitters time and frequency of the received signal with the expected signal based on the time and frequency shifted parameters of the expected signal to provide respective correlation measures therebetween,

[0021] deriving, using said correlation surface, a computational expression indicative of the value of the correlation at a point displaced in time by the time offset plus the time shift and displaced in frequency by the frequency offset plus the frequency shift, and

[0022] comparing the correlation measure with the computational expression to determine the time offset and the frequency offset.

[0023] In the present invention, there is provided a method and corresponding means that embodies an algorithm that is designed to compute the result of a process of correlating the received baseband signal with a non-ideal—that is, a locally reconstructed (i.e. in the receiver)—signal. In this context, non-ideal indicates that the frequency used does not coincide with actual frequency (i.e. transmitter frequency), and time used does not coincide with actual time (i.e. transmitter clock time). As a result of a given set of correlations offset in time and frequency, the algorithm can be utilised to identify in a single process: (a) what the actual offsets are, and (b) what the actual time is. In conventional CDMA and GPS systems bit Synchronisation, Automatic Frequency Control (AFC) and Symbol demodulation are separate processes. The present invention deals with these issues simultaneously.

[0024] Other aspects and features of the invention are defined in the claims.

[0025] Because of the increased sensitivity that the present invention provides, the invention is particularly useful in the tracking, and demodulation of weak signals, thus providing for improved reception of transmitted signals and synchronisation thereof. More specifically, in prior art methods, in order to obtain a GPS fix where the incoming signal is weak, within say a building, it was often necessary to perform long correlations. However, by means of the invention, correlations may be shortened thereby making it feasible to obtain synchronisation without prior knowledge of the transmitted bit sequence. For instance, in the prior art, correlation periods for GPS are in the order of a half second. By means of the present invention, correlation periods may be of the order of 20 msec. Furthermore, in known GPS, in order to correlate over more than 20 msec it is necessary to know the data modulated by the chips. With this invention this is not necessary as correlation is possible over periods shorter than 20 msec whilst still obtaining bit synchronisation and demodulation even for weak signals.

[0026] Preferred features of the invention and their corresponding advantages will be understood from the description below of the various embodiments of the invention. Such embodiments are given merely as examples of specific ways of putting the invention into effect, and are described with reference to the accompanying drawings in which:

[0027]FIG. 1 illustrates an example of a correlation surface in accordance with an embodiment of the present invention;

[0028]FIGS. 2 and 3 are block diagrams for obtaining a correlation surface; and

[0029]FIG. 4 is a plot of time and frequency pairs.

[0030] In spread spectrum systems such as WCDMA, GPS, TDD, unlike analogue systems, a single received pulse is not sufficient to decode the information in a message symbol. Typically in spread spectrum systems each system user has a unique code comprising a string of 1s and (−1s) for example {1, −1, 1, −1, −1, 1}. Each bit of the bit stream to be transmitted would then be spread using the unique code allocated to the user to create a number of pulses. When a pulse stream is received a correlation operation is performed in order to decode the received message. The higher the number of spread bits that are received correctly, the higher the correlation. The correlation is generally achieved by multiplying the received spread bits by the known unique code. If the bit has been correctly received the result will be a large positive number. If not it will be small and may be lost in the noise. In spread spectrum systems, the number of errors received or the bit error rate provides an indication of the strength of the signal.

[0031] The present invention is concerned with acquiring bit synchronisation and frequency synchronisation together. The invention utilizes the insight that part of the signal that is used for synchronisation is known to the receiver. The frequency f and the time t used by the receiver to reconstruct the signal are regarded as unknowns. Typically in spread spectrum systems, the receiver clock is required to perform to a specified accuracy and what is unknown is the extent to which it deviates from the ideal (that is, transmitter) clock frequency. Equations are set up that are then solved for these unknowns.

[0032] A receiver operating in accordance with the invention has stored therein a correlating surface, and the incoming signal is processed and compared to the correlating surface, and computations are made that lead to the resolution of unknown variables of frequency offset and time offset. Each of these aspects of obtaining the frequency and time offsets will be described below in detail section by section. Further, it should be noted that whilst the preferred method for carrying out the invention is described below with reference to GPS, the methods described are applicable more generally to all spread spectrum systems.

[0033] Defining the Correlation Surface

[0034] In a preliminary stage of the present invention, there is defined a correlation surface. The correlation surface is derived from knowledge of the spreading codes of the transmitter. Hence, the correlation surface can be pre-determined and plotted. FIG. 1 shows an ideal correlation surface for the case of a GPS modulated signal as the frequency and time

[0035] Δf, Δt

[0036] respectively are varied. The correlation surface is smooth and continuous.

[0037] Correlation is a process that outputs a value given two inputs. The value is set to 1 when both the inputs are identical. The value decreases as the frequency of the two signals differs by a small amount. Similarly the value of the correlation decreases if one signal has been generated using a clock that is offset from the first clock.

[0038] Therefore, the correlation process can be characterised by a function with two inputs, time offset, and frequency offset. This two valued function describes a convex surface.

[0039] Mathematically, the ideal correlation surface may be determined as follows:

[0040] The ideal correlation function is defined at time t, which is the value of the correlation of the received function, as

[0041] r[t]

[0042] was equal to

[0043] s[f0, t]

[0044] and where f0 is the ideal frequency. Then ideal correlation is given by IdealCorrelation[Δ  f, Δ  t][t] = ∫_(t)^(t + tc)s[f0, τ](s[f0 + Δ  f, Δt + τ]) * t

[0045] In most of the cases it is assumed that the function is stationary and is independent of time t.

[0046] In this case, having determined the correlation surface, it is noted that the surface can be approximated perhaps more efficiently using Box Splines. Alternatively, it is not necessary to calculate the surface. The values of the surface at points can be determined for incremental variables

[0047] (i δt, j δf)

[0048] as input test bits using the arrangements shown in FIGS. 2 and 3.

[0049] As a further refinement, by including the IF filter and the system clock in the chain of processes, the degradation introduced into the system (eg a GPS receiver) by the IF filter and the Allen variance of the clock can be incorporated. These can be determined experimentally for different integer values of I and j and the correlation surface can be obtained using interpolation and Box Splines. As the surface is smooth, it is believed that a cubic Spline should be sufficient. The order of the Splines required depends on the separation of the points. Alternatively, the correlation surface may be provided in the form of a look-up table.

[0050] The correlation surface is thus predefined and stored in a memory of the receiver.

[0051] Representation of the Received GPS Signal

[0052] This section serves to provide a mathematical transformation/representation of the incoming signals that are received at the receiver.

[0053] In reaching the receiver, the signal transmitted by a transmitter follows more than one path, having reflected off natural or man-made obstacles. Thus, signals arrive along two or more different paths and are separated in time relative to each other. The point of maximum correlation power needs to be determined for each path in order to identify the chip where synchronisation/correlation occurs for each path.

[0054] In order to set up the mathematical representation, first a set of variables are defined as follows:

[0055] Time at the Baseband of the receiver is denoted by:

[0056] t_(Re)

[0057] Time at the transmitter is denoted by:

[0058] t

[0059] One of the problems associated with building a receiver is to generate the correct frequencies. Frequency at the transmitter (ie the desired transmitter frequency) is denoted by:

[0060] f0

[0061] which is a constant.

[0062] The frequency at which the receiver is operating is denoted by:

[0063] f_(Re)

[0064] Then, the difference between respective receiver and transmitter clocks is given by:

fRE−fo=Foffset

[0065] The signal

[0066] S_(Tr)[t]

[0067] transmitted at the transmitter can be expressed as a general representation of the transmitter encoded bit sequence according the particular modulation scheme: ${S_{Tr}\left\lbrack {{f0},t} \right\rbrack}\overset{df}{=}{\sum\limits_{k = {- \infty}}^{\infty}{\sum\limits_{l = 0}^{M - 1}{{B\lbrack k\rbrack}{{Ch}\lbrack l\rbrack}{g\left\lbrack {{f0},{t - {kT} - {lTc}}} \right\rbrack}}}}$

[0068] where Chip[l], B[k] are drawn from a known alphabet (eg. (0,1), (−1,1) etc). In CDMA, Chip[l] is known for all l=0, 1, 2 . . . M−1. f[t]=0 for Abs[t]>^(k)0T where ^(k)0 is a constant. And where

[0069] B[k]

[0070] is the k th Bit to be transmitted,

[0071] T

[0072] is the bit period,

[0073] Tc

[0074] is the chip period (also known as the symbol period),

[0075] M

[0076] is the spreading factor of the code, and hence

[0077] T=Tc M

[0078] and where

[0079] g[f, t]

[0080] is the modulating function that depends on the frequency of the modulator and time of the modulator clock. The function g varies depending on the spread spectrum system, eg GPS, WCDMA etc.

[0081] As indicated above, the signal at the receiver is composed of signals arriving via many paths each path with an attendant delay. This is expressed as: ${S_{Re}\lbrack t\rbrack}\overset{df}{=}{\sum\limits_{m = 1}^{NumberOfPaths}{{\alpha \lbrack m\rbrack}{S_{Tr}\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{t - {\Delta \quad {t\lbrack m\rbrack}}}} \right\rbrack}}}$

[0082] where

[0083] α[m]

[0084] is the signal strength, m being the path label.

[0085] Δf [m]

[0086] is the shift in frequency caused by the relative movement between the transmitter and the receiver (Doppler shift), or the movement of one of the reflectors of the signal relative to the receiver and where

[0087] Δt[m]

[0088] is the time it takes for the signal to arrive at the receiver through the mth path.

[0089] The processing that is performed on the signal may be considered to be like filtering and mixing. At this point, the IF filter may be considered, although for simplicity not the mixer. The signal also represents the baseband signal

S _(IF) t{double overscore (df)}S _(Re) t*fil _(IF) t

[0090] here represents a convolution operation.

[0091] Thus, baseband signal as a result of multi-paths may be represented as follows: ${S_{IF}\lbrack t\rbrack} = {\sum\limits_{m = 1}^{NumberOfPaths}{\left( {{\alpha \lbrack m\rbrack}{S_{Tr}\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{t + {\Delta \quad {t\lbrack m\rbrack}}}} \right\rbrack}} \right)*{{fil}_{IF}\lbrack t\rbrack}}}$ ${S_{IF}\lbrack t\rbrack} = {\sum\limits_{m = 1}^{NumberOfPaths}{\begin{matrix} \left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{\sum\limits_{l = 0}^{M - 1}{{B\lbrack k\rbrack}{{Ch}\lbrack l\rbrack}g\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},} \right.}}} \right.} \right. \end{matrix}\begin{matrix} {\left. \left. \left. {t - {kT} - {lTc} + {\Delta \quad {t\lbrack m\rbrack}}} \right\rbrack \right) \right)*{fil}_{IF}\begin{matrix} \lbrack t\rbrack \end{matrix}} \end{matrix}}}$ Factoring    gives                                   ${S_{IF}\lbrack t\rbrack} = {\sum\limits_{m = 1}^{NumberOfPaths}\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\quad \left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}\quad \left( {{g\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{t - {kT} - {lTc} + {\Delta \quad {t\lbrack m\rbrack}}}} \right\rbrack}*{fil}_{IF}\begin{matrix} \lbrack t\rbrack \end{matrix}} \right)}} \right)}} \right)} \right)}$

[0092] The convolution can be expressed as: ${S_{IF}\lbrack t\rbrack} = {\sum\limits_{m = 1}^{NumberOfPaths}\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\quad \left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{\int_{- \infty}^{\infty}{\left( {{g\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{t - t_{1} - {kT} - {lTc} + {\Delta \quad {t\lbrack m\rbrack}}}} \right\rbrack}{fil}_{IF}\begin{matrix} \left\lbrack t_{1} \right\rbrack \end{matrix}} \right){t_{1}}}}}} \right)}} \right)} \right)}$

[0093] In terms of the receiver time

[0094] t_(Re) ${S_{IF}\left\lbrack t_{Re} \right\rbrack} = {\sum\limits_{m = 1}^{NumberOfPaths}\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\quad \left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{\int_{- \infty}^{\infty}{\left( {{g\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{t_{Re} - t_{1} - {kT} - {lTc} + {\Delta \quad {t\lbrack m\rbrack}}}} \right\rbrack}{fil}_{IF}\begin{matrix} \left\lbrack t_{1} \right\rbrack \end{matrix}} \right){t_{1}}}}}} \right)}} \right)} \right)}$

[0095] This is a mathematical representation of the received signal at baseband.

[0096] Correlation with Time and Frequency Shifted Expected Signal

[0097] One of the inputs for the correlation is the received signal at baseband signal. This signal according to the receiver's clock is given by:

[0098] S_(IF)[t_(Re)]

[0099] The other signal needed for correlation in terms of the kth bit being transmitted is the correlating signal defined below: ${{{CorrelatingSignal}\quad\lbrack k\rbrack}\left\lbrack {f,t} \right\rbrack}\overset{df}{=}\left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{g\left\lbrack {f,{t - {kT} - {lTc}}} \right\rbrack}}} \right)$

[0100] This correlating signal is a local reproduction of the signal that the transmitter generates in order to transmit the kth symbol using the spreading chips Ch[l].

[0101] The receiver aims to ascertain the time the signal has taken to reach it. In doing so it generates a correlating signal as follows:

CorrelatingSignal [k][f+μ, t _(Re) +τ+Δt _(Re) [n]]

[0102] for the nth path and correlates it with the incoming processed signal, where

[0103] Δt_(Re)[n]

[0104] is the estimate that the receiver has made of the time the signal takes to reach it, in other words the time lag. This estimate may be based on the value that was used previously (e.g. when the receiver is in tracking mode), or it is in search mode and it is merely trying out the value in order to obtain coarse acquisition. And where:

[0105] μ

[0106] is the offset in frequency in the order of a few Hertz, and

[0107] τ

[0108] is a small offset in time in the order of fractions of a chip period.

[0109] The result of performing the correlation to get the contribution from the nth path to the kth bit leads to ${{{{\Gamma \lbrack n\rbrack}\left\lbrack {\mu,\tau} \right\rbrack} = {\int_{- {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}}^{T - {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}}\left( {{S_{IF}\left\lbrack t_{Re} \right\rbrack}\left. \left( {{{CorrelatingSignal}\lbrack k\rbrack}\left\lbrack {{f + \mu},{t_{Re} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}}} \right\rbrack} \right) \right.\hat{}} \right.}}{*)}}{t_{Re}}$

[0110] where

[0111] Γ[n][μ, τ]

[0112] is the result of the correlation shifted in frequency by

[0113] μ

[0114] and

[0115] τ

[0116] is the offset in time for the nth path.

[0117] Making the substitution in the equation above for the baseband signal

[0118] S_(IF)[t_(Re)]

[0119] leads to: ${{\Gamma \lbrack n\rbrack}\left\lbrack {\mu,\tau} \right\rbrack} = {\int_{- {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}}^{T - {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}}{\left( {\sum\limits_{m = 1}^{NumberOfPaths}{\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{\int_{- \infty}^{\infty}{\left( {{g\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{t_{Re} - t_{1} - {kT} - {lTc} + {\Delta \quad {t\lbrack m\rbrack}}}} \right\rbrack}{fil}_{IF}\begin{matrix} \left\lbrack t_{1} \right\rbrack \end{matrix}} \right){t_{1}}}}}} \right)}} \right)} \right){{{{CorrelatingSignal}\quad\lbrack k\rbrack}\left\lbrack {{f + \mu},{t_{Re} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}}} \right\rbrack}\hat{}\begin{matrix} * \end{matrix}}}} \right)\quad {t_{Re}}}}$

[0120] The order of performing the integral may be changed thus: ${{\Gamma \lbrack n\rbrack}\left\lbrack {\mu,\tau} \right\rbrack} = \left( {\sum\limits_{m = 1}^{NumberOfPaths}{\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{\int_{- {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}}^{T - {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}}\left( {\int_{- \infty}^{\infty}{\left( {{g\left\lbrack \quad {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{t_{Re} - t_{1} - {kT} - {lTc} + {\Delta \quad {t\lbrack m\rbrack}}}} \right\rbrack}{fil}_{IF}\begin{matrix} \left\lbrack t_{1} \right\rbrack \end{matrix}} \right){t_{1}}}} \right)}}} \right)}} \right){\left( {{{CorrelatingSignal}\quad\lbrack k\rbrack}\left\lbrack {{f + \mu},{t_{Re} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}}} \right\rbrack} \right)\hat{}\begin{matrix} * \end{matrix}}} \right)\quad {t_{Re}}}} \right)$

[0121] This is followed by a change in variable. This is a mathematical representation of how the final output is related to the correlation surface.

t2=t _(Re) +Δt[m]

[0122] in the equation ${{\Gamma \lbrack n\rbrack}\left\lbrack {\mu,\tau} \right\rbrack} = \left( {\sum\limits_{m = 1}^{NumbberOfPaths}{\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{\int_{{- {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}} + {\Delta \quad {t{\lbrack m\rbrack}}}}^{T - {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})} + {\Delta \quad {t{\lbrack m\rbrack}}}}\left( {\int_{- \infty}^{\infty}{\left( {{g\left\lbrack \quad {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{{t2} - t_{1} - {kT} - {lTc}}} \right\rbrack}{fil}_{IF}\begin{matrix} \left\lbrack t_{1} \right\rbrack \end{matrix}} \right){t_{1}}}} \right)}}} \right)}} \right){\left( {{{CorrelatingSignal}\quad\lbrack k\rbrack}\left\lbrack {{f + \mu},{{t2} - {\Delta \quad {t\lbrack m\rbrack}} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}}} \right\rbrack} \right)\hat{}\quad \begin{matrix} * \end{matrix}}} \right)\quad {{t2}}}} \right)$

[0123] Replacing the integral in the computation back to convolution leads to: ${{\Gamma \lbrack n\rbrack}\left\lbrack {\mu,\tau} \right\rbrack} = \left( {\sum\limits_{m = 1}^{NumbberOfPaths}{\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{\int_{{- {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}} + {\Delta \quad {t{\lbrack m\rbrack}}}}^{T - {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})} + {\Delta \quad {t{\lbrack m\rbrack}}}}\left( {{g\left\lbrack \quad {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},{{t2} - t_{1} - {kT} - {lTc}}} \right\rbrack}*{fil}_{IF}\begin{matrix} \left\lbrack t_{2} \right\rbrack \end{matrix}} \right)}}} \right)}} \right){\left( {{{CorrelatingSignal}\quad\lbrack k\rbrack}\left\lbrack {{f + \mu},{{t2} - {\Delta \quad {t\lbrack m\rbrack}} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}}} \right\rbrack} \right)\hat{}\quad \begin{matrix} * \end{matrix}}} \right)\quad {{t2}}}} \right)$

[0124] Mapping onto the Correlation Surface

[0125] In this section, the time and frequency offsets of the received signal with the ideal signal are mapped together with the shifted time and frequency values

[0126] onto the correlation surface to provide a computational expression. The correlation surface was defined previously. ${{CorrelatingSurface}\quad\left\lbrack {\mu,\tau} \right\rbrack}\overset{df}{=}\left( {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}{\int_{- \tau}^{T - \tau}{\begin{matrix} \left( \left( {{g\left\lbrack {{f0},{{t2} - t_{1} - {kT} - {1{Tc}}}} \right\rbrack}*{{fil}_{IF}\left\lbrack t_{2} \right\rbrack}} \right) \right. \end{matrix}\begin{matrix} {{\left. \left( {{{CorrelatingSignal}\quad\lbrack k\rbrack}\quad \begin{matrix} \left\lbrack {{f + \mu},{{t2} + \tau}} \right\rbrack \end{matrix}} \right) \right.\hat{}{*)}}{{t2}}} \end{matrix}}}}} \right)$

[0127] With the time and frequency differences put into the correlation equation, then

Abs[f=f0=Δf[m]+μ]<2Hz

[0128] and

Abs[=Δt[m]+ r+Δt _(Re)[n]]Δ $\left( {\begin{matrix} {\begin{matrix} \begin{matrix} {\sum\limits_{l = 0}^{M - 1}{{{Ch}\lbrack l\rbrack}\int_{{- {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})}} + {\Delta \quad {t{\lbrack m\rbrack}}}}^{T - {({\tau + {\Delta \quad {t_{Re}{\lbrack n\rbrack}}}})} + {\Delta \quad {t{\lbrack m\rbrack}}}}}} \end{matrix} \end{matrix}\begin{matrix} \left( \left( {g\left\lbrack {{{f0} + {\Delta \quad {f\lbrack m\rbrack}}},} \right.} \right. \right. \end{matrix}} \end{matrix}\begin{matrix} \left. \left. {{t2} - t_{1} - {kT} - {1{Tc}}} \right\rbrack*{{fil}_{IF}\left\lbrack t_{2} \right\rbrack} \right) \end{matrix}\begin{matrix} \begin{matrix} {\left. {{\left( {{{CorrelatingSignal}\quad\lbrack k\rbrack}\quad\left\lbrack {{f + \mu},\left. \begin{matrix} \left. \left. {{t2} - {\Delta \quad {t\lbrack m\rbrack}} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}} \right\rbrack \right) \end{matrix} \right.\hat{}} \right.} \right.{*)}}{{t2}}} \right) =} \end{matrix} \end{matrix}\begin{matrix} {{CorrelatingSurface}\quad\left\lbrack {{f - {f0} - {\Delta \quad {f\lbrack m\rbrack}} + \mu},{{{- \Delta}\quad {t\lbrack m\rbrack}} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}}} \right\rbrack} \end{matrix}} \right.$

[0129] Tc

[0130] The correlating surface expression derived previously can now be substituted into the above expression: ${{\Gamma \lbrack n\rbrack}\quad\left\lbrack {\mu,\tau} \right\rbrack} = \left( {\underset{{m = 1}\quad}{\overset{NumbberOfPaths}{\sum\quad}}\left( {{\alpha \lbrack m\rbrack}\left( {\sum\limits_{k = {- \infty}}^{\infty}{{B\lbrack k\rbrack}\quad {{CorrelatingSurface}\quad\left\lbrack {{f - {f0} - {\Delta \quad {f\lbrack m\rbrack}} + \mu},{{{- \Delta}\quad {t\lbrack m\rbrack}} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}}} \right\rbrack}}} \right)} \right)} \right)$

[0131] The above expression will be non zero for only those cases where ${{Abs}\quad\left\lbrack {{{- \Delta}\quad {t\lbrack m\rbrack}} + \tau + {\Delta \quad {t_{Re}\lbrack n\rbrack}}} \right\rbrack} < {\frac{1}{2}{Tc}}$

[0132] As indicated earlier, synchronisation aims to establish determining the value

[0133] τ0

[0134] and

[0135] μ0

[0136] so that

f−f0−Δf[m]+μ0=0

[0137] and

−Δt[m]+τ0+Δt _(Re) [n]=0

[0138] Prediction of the Correlating Result using the Correlating Surface

[0139] For a receiver that is synchronised both in time and frequency for the nth path, it is not necessary to make an adjustment and in these circumstances the value

[0140] Γ[n][μ, τ]

[0141] can be predicted by

Γ[n][μ, τ]=(α[m]B[k]CorrelatingSurface[μ, τ])

[0142] where the contribution from all other paths is assumed to be zero. For simplicity, the value of B[k] is taken to be 1

[n][μ, τ]=(α[m]CorrelatingSurface[μ, τ])

[0143] When the system is not perfectly synchronised, the time requires adjustment by say

[0144] τ0

[0145] and the frequency by

[0146] μ0

[0147] The expected result is therefore modified to be:

Γ[n][μ, τ]=(α[m]CorrelatingSurface[μ+μ0, τ+τ0])

[0148] For GPS system, offsets are given by

[0149] μ

[0150] in Hz and

[0151] τ

[0152] in units of T, and the correlating surface is $\begin{matrix} {{{CorrelatingSurface}\left\lbrack \left\{ {{\mu\_},{\tau\_}} \right\} \right\rbrack}:=\quad {{1.0282397173771807\quad}^{\backprime} -}} \\ {\quad {{{0.6561546163982793\quad}^{\backprime}\mu} +}} \\ {\quad {{{0.16121834444658398\quad}^{\backprime}\mu^{2}} -}} \\ {\quad {{{0.041119148280990614\quad}^{\backprime}\tau} +}} \\ {\quad {{{0.531238073030845\quad}^{\backprime}{\mu\tau}} -}} \\ {\quad {{{0.5671706714002305\quad}^{\backprime}\mu^{2}\tau} -}} \\ {\quad {{{0.005007915014931778\quad}^{\backprime}\tau^{2}} -}} \\ {\quad {{{0.0571012049318205\quad}^{\backprime}{\mu\tau}^{2}} +}} \\ {\quad {{0.09078005351970127\quad}^{\backprime}\mu^{2}\tau^{2}}} \end{matrix}$

[0153] Therefore, with a shift in frequency by 0.1 Hz and by 0.1 Tc, the following algebraic expression is expected:

(α[m]CorrelatingSurface[{0.1+μ0, 0.1 +τ0}])//Simplify

[0154] (−0.0389452  μ0  (−8.83503 + τ0)  (−1.69297 + τ0) + 0.0907801  μ0²  (−5.84923 + τ0)  (−0.198513 + τ0) − 0.00981023  (−10.1421 + τ0)  (9.69655 + τ0))  α[m]

[0155] It is noted that this is an algebraic expression in terms of the unknowns

[0156] μ0, τ0, and α[m]

[0157] The actual measured value of the result of the correlation performed earlier is denoted by

[0158] Ξ[n][μ, τ]

[0159] If there was no noise in the received signal, the following equation could be set up:

Γ[n][μ, τ]=Ξ[n][μ, τ]

[0160] Being explicit for the case above, the following equation is obtained involving exactly three unknowns. ${\left( {{\begin{matrix} {{- {0.038945194227880245\quad}^{\backprime}}{{\mu 0}\left( {{- {8.835028210083548\quad}^{\backprime}} + {\tau 0}} \right)}} \end{matrix}\left( {{- {1.6929690957226662\quad}^{\backprime}} + {\tau 0}} \right)} + {{0.09078005351970127\quad}^{\backprime}{{\mu 0}^{2}\left( {{- {5.849232627906463\quad}^{\backprime}} + {\tau 0}} \right)}\left( {{- {0.19851287796220235\quad}^{\backprime}} + {\tau 0}} \right)} - {{0.009810234972916814\quad}^{\backprime}\left( {{- {10.142097500134339\quad}^{\backprime}} + {\tau 0}} \right)\left( {{9.696552074813233\quad}^{\backprime} + {\tau 0}} \right)}} \right){\alpha \lbrack m\rbrack}}{{\Xi \quad\lbrack n\rbrack}\left\lbrack {0.1,0.1} \right\rbrack}$

[0161] By setting up three different equations, the unknowns can be determined. This is however not strictly the case as there is noise present in the system. The following algebraic expression is set up including the noise

(α[m]CorrelatingSurface[{μ+μ0, τ+τ0}])−Ξ[n][{μ, τ}])^ 2

[0162] This expression is obtained by subtracting the predicted algebraic expression from the actual measured correlation result and squaring the result of the subtraction.

[0163] This is carried for several different values of

[0164] {μ, τ}

[0165] For instance, let the set of values over which this operation is performed be denoted TimeFreqShifts, then $\begin{matrix} {{TimeFreqShifts} = \quad \left\{ {\left\{ {0,{{- 3}\quad \delta \quad t}} \right\},\left\{ {0,{{- 2}\quad \delta \quad t}} \right\},\left\{ {{{- \delta}\quad f},{{- 2}\quad \delta \quad t}} \right\},} \right.} \\ {\quad {\left\{ {{\delta \quad f},{{- 2}\quad \delta \quad t}} \right\},\left\{ {0,{{- \delta}\quad t}} \right\},\left\{ {{{- \delta}\quad f},{{- \delta}\quad t}} \right\},}} \\ {\quad {\left\{ {{\delta \quad f},{{- \delta}\quad t}} \right\},}} \\ {\quad {\left\{ {{{- 2}\quad \delta \quad f},{{- \delta}\quad t}} \right\},\left\{ {{2\quad \delta \quad f},{{- \delta}\quad t}} \right\},\left\{ {0,0} \right\},}} \\ {\quad {\left\{ {{{- \delta}\quad f},0} \right\},\left\{ {{\delta \quad f},0} \right\},\left\{ {{{- 2}\quad \delta \quad f},0} \right\},\left\{ {{2\quad \delta \quad f},0} \right\},}} \\ {\quad {\left\{ {{{- 3}\quad \delta \quad f},0} \right\},}} \\ {\quad {\left\{ {{3\quad \delta \quad f},0} \right\},\left\{ {0,{\delta \quad t}} \right\},\left\{ {{{- \delta}\quad f},{\delta \quad t}} \right\},\left\{ {{\delta \quad f},{\delta \quad t}} \right\},}} \\ {\quad {\left\{ {{{- 2}\quad \delta \quad f},{\delta \quad t}} \right\},\left\{ {{2\quad \delta \quad f},{\delta \quad t}} \right\},\left\{ {0,{2\quad \delta \quad t}} \right\},}} \\ {{\quad \left. {\left\{ {{{- \delta}\quad f},{2\quad \delta \quad t}} \right\},\left\{ {{\delta \quad f},{2\quad \delta \quad t}} \right\},\left\{ {0,{3\quad \delta \quad t}} \right\}} \right\}};} \end{matrix}$

[0166] and for each element

[0167] λ

[0168] in TimeFreqShifts the expected noise is calculated according to:

(μ[m]CorrelatingSurface[{μ+μ0, τ+τ0}])−Ξ[n][{μ, τ}])^ 2

[0169] where

[0170] λ={μ, τ}

[0171] Several noise contributions are then added together to arrive at an algebraic expression for the total noise as a function of the unknowns

[0172] μ0, τ0, and α[m] $\sum\limits_{\lambda \in {TimeFreqShifts}}{\left( {{{\alpha \lbrack m\rbrack}{{CorrelatingSurface}\left\lbrack \left\{ {{\mu + {\mu 0}},{\tau + {\tau 0}}} \right\} \right\rbrack}} - {{\Xi \quad\lbrack n\rbrack}\lbrack\lambda\rbrack}} \right)\hat{}2}$

CorrelatingSurface[{μ+μ0, τ+τ0}]−Ξ[n][λ])^ 2

[0173] and where λ={μ, τ}

[0174] This expression is called the Cost. ${Cost} = \overset{{df}\quad}{\sum\limits_{\lambda \in {TimeFreqShifts}}\left( {{{\alpha \lbrack m\rbrack}{{CorrelatingSurface}\left\lbrack \left\{ {{\mu + {\mu 0}},{\tau + {\tau 0}}} \right\} \right\rbrack}} - {{\Xi \quad\lbrack n\rbrack}\lbrack\lambda\rbrack}} \right)^{2}}$

[0175] The cost is an implicit function of the set TimeFreqShifts and the unknowns

[0176] μ0, τ0, and α[m]

[0177] Any standard mathematical procedure can now be employed for minimising the expression to find the values for the unknowns that best minimise the cost.

EXAMPLE

[0178] The following example of a preferred implementation of the present invention in an example run in the computer program Mathematica 4.

[0179] One method that can be used for finding the values is given in the following example for

[0180] τ0

[0181] and

[0182] μ0

[0183] Any assumptions involved in the demonstration in that there exists exactly one path such that

−Δt[m]+Δt _(Re) [n]=0.4Tc

[0184] For all other paths it is assumed:

Abs[−Δt[m]+Δt _(Re) [n]]>3Tc

f−f0−Δf[m]=0.35 Hz

[0185] Let the strength

[0186] α[m]=0.8

[0187] Assume B[k]=1;

[0188] In the sequel, all the time units are in Tc, chip periods and all the frequencies are in Hz.

[0189] This assumption is consistent with the system tracking one path. Under these assumptions the following is arrived at:

Γ[n][μ, τ]=0.8CorrelatingSurface[μ+0.35, τ+0.4]

[0190] For GPS the correlation surface function is calculated to be: $\begin{matrix} {{{CorrelationSurface}\left\lbrack \left\{ {{\mu\_},{\tau\_}} \right\} \right\rbrack}:=\quad {{1.0282397173771807\quad}^{\backprime} -}} \\ {\quad {{{0.6561546163982793\quad}^{\backprime}\mu} +}} \\ {\quad {{{0.16121834444658398\quad}^{\backprime}\mu^{2}} -}} \\ {\quad {{{0.041119148280990614\quad}^{\backprime}\tau} +}} \\ {\quad {{{0.531238073030845\quad}^{\backprime}{\mu\tau}} -}} \\ {\quad {{{0.5671706714002305\quad}^{\backprime}\mu^{2}\tau} -}} \\ {\quad {{{0.005007915014931778\quad}^{\backprime}\tau^{2}} -}} \\ {\quad {{{0.0571012049318205\quad}^{\backprime}{\mu\tau}^{2}} +}} \\ {\quad {{0.09078005351970127\quad}^{\backprime}\mu^{2}\tau^{2}}} \end{matrix}$

[0191] For simplicity in this example, a set of time shift and frequency shift pairs have been defined over which to estimate the correlation function for each path.

[0192] δt=0.1;δf=0.1;

[0193] The time shift and frequency pairs are conveniently taken from the topology diagram from FIG. 4.

[0194]FIG. 4 shows a topological function that assigns more correlators to the centre frequency. It may in the context of a specific situation be more appropriate to assign more correlators in the frequency that is most likely. $\begin{matrix} {{TimeFreqShifts} = \quad \left\{ {\left\{ {0,{{- 3}\delta \quad t}} \right\},\left\{ {0,{{- 2}\delta \quad t}} \right\},\left\{ {{{- \delta}\quad f},{{- 2}\quad \delta \quad t}} \right\},} \right.} \\ {\quad {\left\{ {{\delta \quad f},{{- 2}\delta \quad t}} \right\},\left\{ {0,{{- \delta}\quad t}} \right\},\left\{ {{{- \delta}\quad f},{{- \delta}\quad t}} \right\},}} \\ {\quad {\left\{ {{\delta \quad f},{{- \delta}\quad t}} \right\},}} \\ {\quad {\left\{ {{{- 2}\delta \quad f},{{- \delta}\quad t}} \right\},\left\{ {{2\delta \quad f},{{- \delta}\quad t}} \right\},\left\{ {0,0} \right\},}} \\ {\quad {\left\{ {{{- \delta}\quad f},0} \right\},\left\{ {{\delta \quad f},0} \right\},\left\{ {{{- 2}\delta \quad f},0} \right\},\left( {{2\delta \quad f},0} \right\},}} \\ {\quad {\left\{ {{{- 3}\delta \quad f},0} \right\},}} \\ {\quad {\left\{ {{3\delta \quad f},0} \right\},\left\{ {0,{\delta \quad t}} \right\},\left\{ {{{- \delta}\quad f},{\delta \quad t}} \right\},\left\{ {{\delta \quad f},{\delta \quad t}} \right\},}} \\ {\quad {\left\{ {{{- 2}\delta \quad f},{\delta \quad t}} \right\},\left\{ {{2\delta \quad f},{\delta \quad t}} \right\},\left\{ {0,{2\delta \quad t}} \right\},}} \\ {\left. \quad {\left\{ {{{- \delta}\quad f},{2\delta \quad t}} \right\},\left\{ {{\delta \quad f},{2\delta \quad t}} \right\},\left\{ {0,{3\delta \quad t}} \right\}} \right\};} \end{matrix}$

[0195] It is necessary then to calculate the result of the correlation

[0196] Γ[n][μ, τ]

[0197] given baseband signal is correlated with a signal that has been shifted in frequency and time by

[0198] {μ, τ}

[0199] It is convenient to store the result of this in the form

[0200] {{μ, τ}, Γ[n][μ, τ]}

[0201] for all different frequency shift time combinations for one particular path {Γ[n][0, −3  δ  t], Γ[n][0, −2  δ  t], Γ[n][−δ  f, −2  δ  t], Γ[n][δ  f, −2  δ  t], Γ[n][0, −δ  t], Γ[n][−δ  f, −δ  t], Γ[n][δ  f, −δ  t], Γ[n][−2  δ  f, −δ  t], Γ[n][2  δ  f, −δ  t], Γ[n][0, 0], Γ[n][−δ  f, 0], Γ[n][δ  f, 0], Γ[n][−2  δ  f, 0], Γ[n][2  δ  f, 0], Γ[n][−3  δ  f, 0], Γ[n][3  δ  f, 0], Γ[n][0, δ  t], Γ[n][−δ  f, δ  t], Γ[n][δ  f, δ  t], Γ[n][−2  δ  f, δ  t], Γ[n][2  δ  f, δ  t], Γ[n][0, 2  δ  t], Γ[n][−δ  f, 2  δ  t], Γ[n][δ  f, 2  δ  t], Γ[n][0, 3  δ  t]}

[0202] The list is denoted by the term OutputOfArrayOfCorrelators.

[0203] For GPS, the result of the correlator leads to the following. $\begin{matrix} {{OutputOfArrayOfCorrelators} = \quad \left\{ \left\{ {\left\{ {0,{- {0.30000000000000004\quad}^{\backprime}}} \right\},} \right. \right.} \\ {\left. \quad {0.6605837584271745\quad}^{\backprime} \right\},} \\ {\quad {\left\{ {\left\{ {0,{- 0.2^{\backprime}}} \right\},{0.6662776733053989\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.1^{\backprime}},{- 0.2^{\backprime}}} \right\},{0.7079850175137978\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.1^{\backprime},{- 0.2^{\backprime}}} \right\},{0.625392975693917\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0,{- 0.1^{\backprime}}} \right\},{0.6717496237006648\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.1^{\backprime}},{- 0.1^{\backprime}}} \right\},{0.7119400152388182\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.1^{\backprime},{- 0.1^{\backprime}}} \right\},{0.631547029728004\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.2^{\backprime}},{- 0.1^{\backprime}}} \right\},{0.7521182043424641\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.2^{\backprime},{- 0.1^{\backprime}}} \right\},{0.5913322333208358\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0,0} \right\},{0.6769996096129723\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.1^{\backprime}},0} \right\},{0.7156772615573921\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.1`^{\backprime},0} \right\},{0.637503955819747\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.2^{\backprime}},0} \right\},{0.7535369116530061\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.2^{\backprime},0} \right\},{0.5971903001777158\quad}^{\backprime}} \right\},}} \\ {\quad \left\{ {\left\{ {{- {0.30000000000000004\quad}^{\backprime}},0} \right\},} \right.} \\ {\left. \quad {0.7905785598998143\quad}^{\backprime} \right\},} \\ {\quad \left\{ {\left\{ {{0.30000000000000004\quad}^{\backprime},0} \right\},} \right.} \\ {\left. \quad {0.5560586426868691\quad}^{\backprime} \right\},} \\ {\quad {\left\{ {\left\{ {0,0.1^{\backprime}} \right\},{0.6820276310423212\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.1^{\backprime}},0.1^{\backprime}} \right\},{0.7191967564695193\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.1^{\backprime},0.1^{\backprime}} \right\},{0.6432637539691456\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.2^{\backprime}},0.1^{\backprime}} \right\},{0.7547711302507397\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.2^{\backprime},0.1^{\backprime}} \right\},{0.6029051252499921\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0,0.2^{\backprime}} \right\},{0.6868336879887117\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {{- 0.1^{\backprime}},0.2^{\backprime}} \right\},{0.7224984999752001\quad}^{\backprime}} \right\},}} \\ {\quad {\left\{ {\left\{ {0.1^{\backprime},0.2^{\backprime}} \right\},{0.6488264241762\quad}^{\backprime}} \right\},}} \\ {\quad \left\{ {\left\{ {0,{0.30000000000000004\quad}^{\backprime}} \right\},} \right.} \\ {\left. \left. \quad {0.6914177804521437\quad}^{\backprime} \right\} \right\};} \end{matrix}$

[0204] Transpose [{TimeFreqShifts, Map [0. 8CorrelationSurface[#+{0. 35, 0.4}] &, TimeFreqShifts]}]

[0205] {{{0, −0.3}, 0.660584}, {{0, −0.2}, 0.666278},

[0206] {{−0.1, −0.2}, 0.707985},

[0207] {{0.1, −0.2}, 0.625393}, {{0, −0.1}, 0.67175},

[0208] {{−0.1, −0.1}, 0.71194},

[0209] {{0.1, −0.1}, 0.631547},

[0210] {{−0.2, −0.1}, 0.752118},

[0211] {{0.2, −0.1}, 0.591332}, {{0, 0}, 0.677},

[0212] {{−0.1, 0}, 0.715677}, {{0.1, 0}, 0.637504},

[0213] {{−0.2, 0}, 0.753537}, {{0.2, 0}, 0.59719},

[0214] {{−0.3, 0}, 0.790579}, {{0.3, 0}, 0.556059},

[0215] {{0, 0.1}, 0.682028}, {{−0.1, 0.1}, 0.719197},

[0216] {{0.1, 0.1}, 0.643264},

[0217] {{−0.2, 0.1}, 0.754771},

[0218] {{0.2, 0.1}, 0.602905}, {{0, 0.2}, 0.686834},

[0219] {{−0.1, 0.2}, 0.722498},

[0220] {{0.1, 0.2}, 0.648826}, {{0, 0.3}, 0.691418}}

[0221] Arranging these in a list, these are the values that are derived:

[0222] TimeFreqShifts

[0223] {{0, −0.3}, {0, −0.2}, {−0.1, −0.2},

[0224] {0.1, −0.2}, {0, −0.1}, {−0.1, −0.1},

[0225] {0.1, −0.1}, {−0.2, −0.1}, {0.2, −0.1},

[0226] {0, 0}, {−0.1, 0}, {0.1, 0}, {−0.2, 0},

[0227] {0.2, 0}, {−0.3, 0}, {0.3, 0},

[0228] {0, 0.1}, {−0.1, 0.1}, {0.1, 0.1},

[0229] {−0.2, 0.1}, {0.2, 0.1}, {0, 0.2},

[0230] {−0.1, 0.2}, {0.1, 0.2}, {0, 0.3}}

[0231] What is also known is the formula for the surface. $\begin{matrix} {{{CorrelationSurface}\left\lbrack \left\{ {{\mu\_},{\tau\_}} \right\} \right\rbrack}:=\quad {{1.0282397173771807\quad}^{\backprime} -}} \\ {\quad {{{0.6561546163982793\quad}^{\backprime}\mu} +}} \\ {\quad {{{0.16121834444658398\quad}^{\backprime}\mu^{2}} -}} \\ {\quad {{{0.041119148280990614\quad}^{\backprime}\tau} +}} \\ {\quad {{{0.531238073030845\quad}^{\backprime}{\mu\tau}} -}} \\ {\quad {{{0.5671706714002305\quad}^{\backprime}\mu^{2}\tau} -}} \\ {\quad {{{0.005007915014931778\quad}^{\backprime}\tau^{2}} -}} \\ {\quad {{{0.0571012049318205\quad}^{\backprime}{\mu\tau}^{2}} +}} \\ {\quad {{0.09078005351970127\quad}^{\backprime}\mu^{2}\tau^{2}}} \end{matrix}$

Cost=Map[

[0232] (a CorrelationSurface[#[[1]]+{μ0, τ0}]−#[[2]])^ 2&, OutputOfArrayOfCorrelators]// Apply[Plus, #]&//Simplify//Expand

[0233] in this case given by: 11.5027 − 35.1259  a + 26.8266  a² + 22.3214  a  μ0 − 34.1526  a²μ0 − 5.48374  a  μ0² + 19.447  a²μ0² − 5.67436  a²μ0³ + 0.8325  a²μ0⁴ + 2.0042  a  τ0 − 3.0949  a²τ0 − 18.4095  a  μ0τ0 + 30.0936  a²μ0τ0 + 19.1592  a  μ²τ0 − 47.5942  a²μ0²τ0 + 23.1414  a²μ0³τ0 − 4.73256  a²μ0⁴τ0 + 0.0823288  a  τ0² + 0.100551  a²τ0² + 2.00361  a  μ0τ0² − 5.01711  a²μ0τ0² − 3.06804  a  μ0²τ0² + 15.825  a²μ0²τ0² − 18.5361  a²μ0³τ0² + 8.79955  a²μ0⁴τ0² − 0.0249395  a²τ0³ + 0.235887  a²μ0τ0³ − 1.88262  a²μ0²τ0³ + 4.0306  a²μ0³τ0³ − 2.57439  a²μ0⁴τ0³ + 0.00207052  a²τ0⁴ − 0.00187509  a²μ0τ0⁴ + 0.0844947  a²μ0²τ0⁴ − 0.259183  a²μ0³τ0⁴ + 0.206025  a²μ0⁴τ0⁴

[0234] The cost function can now be minimised to yield the unknowns.

[0235] Several algorithms can be developed from this cost function, depending on the uncertainties of t and f.

[0236] In order to obtain an initial solution, the time delay and the frequency delay shift values are selected from the OutputArrayCorrelators with the highest correlation value.

[0237] InitialSolution[OutputOfArrayOfCorrelators_, Cost_]:=Module[{x1, x2, x3},

[0238] x1=Sort[OutputOfArrayOfCorrelators, #1[[2]]≧#2[[2]]&]// First;

[0239] x2=Cost/.{μ0→−x1[[1, 1]], τ0→−x1[[1, 2]]};

[0240] x3=Solve[x2=0, a]; {a→(x3[[1, 1, 2]]//Re), μ0→−x1[[1, 1]], τ0→−x1[[1, 2]]}]

[0241] OldSol=InitialSolution[OutputOfArrayOfCorrelators, Cost]

[0242] {a→0.795264, μ0→0.3, τ0→0}

[0243] ImproveSolution[Cost_][OldSol_]:=Module[{x1, x2, x3, x4, x5, x6, x7, x8}, x1=(D[Cost, a]/.{OldSol[[2]], OldSol[[3]]})=0//Solve[#, a]& // Flatten;

[0244] x2=((D[Cost, μ0] /a) //Simplify);

[0245] x3=((x2/. x1/.OldSol[[3]]) // Expand);

[0246] x4=Solve[x3=0, μ0]// Flatten;

[0247] x5=Select[x4, Re[#[[2]]]=#[[2]]&];

[0248] x6=( D[Cost, τ0]/a) // Simplify;

[0249] x7=((x6 /. x1/. x5) // Expand);

[0250] x8=Solve[x7=0, τ0]// Flatten;

[0251] x9=Select[x8, Re[#[[2]]]=#[[2]]&];

[0252] Join[x1, x5, x9]]

[0253] Nest [ImproveSolution[Cost], OldSol, 1000]

[0254] {a→0.799884 , μ0 -0.349689, τ0-0.399462}

[0255] Without prior knowledge of the value of

[0256] f−f0−Δf[m]

[0257] which has been assumed to be 0.35 Hz and

[0258] −Δt[m]+Δt_(Re)[n]

[0259] which has been assumed to be 0.4 Tc

[0260] The present invention may be embodied in other specific forms without departing from its essential attributes. Reference should thus be made to the appended claims and other general statements herein rather than to the foregoing description as indicating the scope of invention.

[0261] Furthermore, each feature disclosed in this specification (which term includes the claims) and/or shown in the drawings may be incorporated in the invention independently of other disclosed and/or illustrated features. In this regard, the invention includes any novel feature or combination of features disclosed herein either explicitly or any generalisation thereof irrespective of whether or not it relates to the claimed invention or mitigates any or all of the problems addressed.

[0262] The appended abstract as filed herewith is included in the specification by reference. 

1. A method for operation of a receiver of a spread spectrum system in which a signal received at the receiver has a received time and frequency and is transmitted from a transmitter in accordance with a predetermined modulation scheme and having a transmitted time and frequency, there being a time offset and a frequency offset between the received signal and the transmitted signal, and in which the receiver includes a predefined correlation surface in accordance with the predetermined modulation scheme, the method comprising: generating in the receiver an expected signal, the expected signal being a function of time and frequency comprising a frequency parameter shifted from the transmitter frequency and a time parameter shifted from the transmitter time, correlating the received time and frequency of the received signal with said time and frequency shifted parameters of the expected signal to provide respective correlation measures therebetween, deriving, using said correlation surface, a computational expression indicative of the value of the correlation at a point displaced in time by the time offset plus the time shift and displaced in frequency by the frequency offset plus the frequency shift, and comparing the correlation measure with the computational expression and determining the time offset and the frequency offset.
 2. A method for operation of a receiver, wherein the step of deriving the computational expression alternatively comprises mapping the time and frequency offset parameters with the time and frequency offsets onto the correlation surface.
 3. A receiver for operating in a spread spectrum system in which a signal received at the receiver has a received time and frequency and is transmitted from a transmitter in accordance with a predetermined modulation scheme with a transmitted time and frequency, there being a time offset and a frequency offset between the received signal and the transmitted signal, and in which the receiver includes a predefined correlation surface in accordance with the predetermined modulation scheme, the receiver comprising: generating means for generating in the receiver an expected signal, the expected signal being a function of time and frequency comprising a frequency parameter shifted from the transmitter frequency and a time parameter shifted from the transmitter time, correlating means for correlating the received time and frequency of the received signal with said time and frequency shifted parameters of the expected signal to provide respective correlation measures therebetween, processing means for deriving, using said correlation surface, a computational expression indicative of the value of the correlation at a point displaced in time by the time offset plus the time shift and displaced in frequency by the frequency offset plus the frequency shift, and comparator means for comparing the correlation measure with the computational expression to determine and output indicative of the time offset and the frequency offset.
 4. A computer program on a carrier for synchronising a receiving operating in a spread spectrum system in which a signal received at the receiver has a received time and frequency and is transmitted from a transmitter in accordance with a predetermined modulation scheme with a transmitted time and frequency, there being a time offset and a frequency offset between the received signal and the transmitted signal, and in which the receiver includes a predefined correlation surface in accordance with the predetermined modulation scheme, the program comprising: generating means for generating in the receiver an expected signal, the expected signal being a function of time and frequency comprising a frequency parameter shifted from the transmitter frequency and a time parameter shifted from the transmitter time, correlating means for correlating the received time and frequency of the received signal with said time and frequency shifted parameters of the expected signal to provide respective correlation measures therebetween, processing means for deriving, using said correlation surface, a computational expression indicative of the value of the correlation at a point displaced in time by the time offset plus the time shift and displaced in frequency by the frequency offset plus the frequency shift, and comparator means for comparing the correlation measure with the computational expression to determine and output indicative of the time offset and the frequency offset.
 5. A computer program product operable to synchronise a receiver in a spread spectrum system in which a signal received at the receiver has a received time and frequency and is transmitted from a transmitter in accordance with a predetermined modulation scheme with a transmitted time and frequency, there being a time offset and a frequency offset between the received signal and the transmitted signal, and in which the receiver includes a predefined correlation surface in accordance with the predetermined modulation scheme, the synchronisation comprising: generating means for generating in the receiver an expected signal, the expected signal being a function of time and frequency comprising a frequency parameter shifted from the transmitter frequency and a time parameter shifted from the transmitter time, correlating means for correlating the received time and frequency of the received signal with said time and frequency shifted parameters of the expected signal to provide respective correlation measures therebetween, processing means for deriving, using said correlation surface, a computational expression indicative of the value of the correlation at a point displaced in time by the time offset plus the time shift and displaced in frequency by the frequency offset plus the frequency shift, and comparator means for comparing the correlation measure with the computational expression to determine and output indicative of the time offset and the frequency offset.
 6. A portable radio communication device including a receiver operable in a spread spectrum system in which a signal received at the receiver has a received time and frequency and is transmitted from a transmitter in accordance with a predetermined modulation scheme with a transmitted time and frequency, there being a time offset and a frequency offset between the received signal and the transmitted signal, and in which the receiver includes a predefined correlation surface in accordance with the predetermined modulation scheme, the receiver comprising: generating means for generating in the receiver an expected signal, the expected signal being a function of time and frequency comprising a frequency parameter shifted from the transmitter frequency and a time parameter shifted from the transmitter time, correlating means for correlating the received time and frequency of the received signal with said time and frequency shifted parameters of the expected signal to provide respective correlation measures therebetween, processing means for deriving, using said correlation surface, a computational expression indicative of the value of the correlation at a point displaced in time by the time offset plus the time shift and displaced in frequency by the frequency offset plus the frequency shift, and comparator means for comparing the correlation measure with the computational expression to determine and output indicative of the time offset and the frequency offset. 